<?php
// $Id$

/**
 * Column 封装来自 _columns 数据表的记录及领域逻辑
 */
class Column extends QDB_ActiveRecord_Abstract
{
    function path($col_id) {
        FUNC::getParent(self::getFormCache(), $col_id, $paths, array('name', 'col_id'));    //查找父亲
        //        dump($parents);
        FUNC::formatArrayKey($paths);
        foreach($paths as $key => $path) {
            $p[] = '<a href="' .url('articles', array('col_id' => $path['col_id'])). '">' .$path['name']. '</a>';
        }
//        dump($p);
        return implode (' > ', $p);
    }

    function getConfig($parent_id) {
        if($this->fields->system->id()) {
            return (object)Helper_YAML::loadCached(dirname(dirname(__FILE__)).'/../'.$this->fields->system->yaml_path.'/'.$this->fields->sys_id.'.yaml');
        }
        
        $column = self::find('col_id = ?', $parent_id) -> one() -> query();
        if(!$column->id()) {
            return '';
        }
        else {
            if($column->fields->sys_id) {
                $yaml = Helper_YAML::loadCached(dirname(dirname(__FILE__)).'/../'.$column->fields->system->yaml_path.'/'.$column->fields->sys_id.'.yaml');
                return (object)$yaml;
            }
            else {
                return $this->getConfig($column->parent_id);
            }
        }
        //        return (object)$yaml;
    }

static function allInOneDropList() {
}

    /**
     * 从缓存中取出栏目
     * @param string $cache_id
     * @param int $ref_id
     * @return array
     */
    static function getFormCache($cache_id = '', $ref_id = null) {
        if(!$cache_id) $cache_id = __CLASS__.'_cache_';

        $refs = Helper_Cache::read($cache_id);
        //        $refs = null; //debug
        //        dump($refs);
        if(!$refs) {
            //                        echo 'caaa';
            $columns = self::find()->all()->query()->toArray();
            //                          exit();

            $tree = Helper_Array::toTree($columns, 'col_id', 'parent_id', 'childrens', $refs);
            Helper_Cache::write($cache_id, $refs);
        }
        if(!$ref_id) {
            return $refs;
        }
        return $refs[$ref_id];
    }

    static function clearCache($cache_id = '') {
        if(!$cache_id) $cache_id = __CLASS__.'_cache_';
        Helper_Cache::write($cache_id, null);
    }

    static function droplist($condi = array(), $attrs = array(), $selected = array(), $skip = array()) {
        if(!$name) $name = $id;
        $str = '<select ';
        foreach($attrs as $key=>$value) {
            $str .= $key.'="' .$value. '"';
        }
        $str .= '>';
        if(!$attrs['caption']) $attrs['caption'] = '搜索全部';
        $str .= '<option value="0">' .$attrs['caption']. '</option>';
        //        $str .= '><option>选择分组</option>';
        $records = self::find($condi)->all()->order('sort DESC')->query();
        foreach($records as $key=>$record) {
            if(in_array($record->col_id, $skip)) {
                continue;
            }
            if($selected && in_array($record->col_id, $selected)) {
                $str .= '<option value="'.$record->col_id.'" selected="selected">' .$record->name. '</option>';
            }
            else {
                $str .= '<option value="'.$record->col_id.'">' .$record->name. '</option>';
            }
        }
        $str .='</select>';
//        dump($str);
        return $str;
    }

    /**
     * 返回对象的定义
     *
     * @static
     *
     * @return array
     */
    static function __define()
    {
        return array
        (
            // 指定该 ActiveRecord 要使用的行为插件
            'behaviors' => '',

            // 指定行为插件的配置
            'behaviors_settings' => array
            (
                # '插件名' => array('选项' => 设置),
            ),

            // 用什么数据表保存对象
            'table_name' => '_columns',

            // 指定数据表记录字段与对象属性之间的映射关系
            // 没有在此处指定的属性，QeePHP 会自动设置将属性映射为对象的可读写属性
            'props' => array
            (
                // 主键应该是只读，确保领域对象的“不变量”
                'col_id' => array('readonly' => true),

                // 对象创建时间应该是只读
                'created' => array('readonly' => true),

                // 对象最后更新时间应该是只读
                'updated' => array('readonly' => true),


                /**
                 *  可以在此添加其他属性的设置
                 */
                # 'other_prop' => array('readonly' => true),

                /**
                 * 添加对象间的关联
                 */
                # 'other' => array('has_one' => 'Class'),
                'fields' => array(
                    'has_one'  => 'ColumnField',
                ),
                'parent' => array(
                    'belongs_to'  => 'Column',
                    'source_key' => 'parent_id',
                    'target_key' => 'col_id',
                ),
                //              'config' => array(
                //                  'getter' => 'getConfig'
                //                ),
            ),

            /**
             * 允许使用 mass-assignment 方式赋值的属性
             *
             * 如果指定了 attr_accessible，则忽略 attr_protected 的设置。
             */
            'attr_accessible' => '',

            /**
             * 拒绝使用 mass-assignment 方式赋值的属性
             */
            'attr_protected' => 'col_id',

            /**
             * 指定在数据库中创建对象时，哪些属性的值不允许由外部提供
             *
             * 这里指定的属性会在创建记录时被过滤掉，从而让数据库自行填充值。
             */
            'create_reject' => '',

            /**
             * 指定更新数据库中的对象时，哪些属性的值不允许由外部提供
             */
            'update_reject' => '',

            /**
             * 指定在数据库中创建对象时，哪些属性的值由下面指定的内容进行覆盖
             *
             * 如果填充值为 self::AUTOFILL_TIMESTAMP 或 self::AUTOFILL_DATETIME，
             * 则会根据属性的类型来自动填充当前时间（整数或字符串）。
             *
             * 如果填充值为一个数组，则假定为 callback 方法。
             */
            'create_autofill' => array
            (
                # 属性名 => 填充值
                # 'is_locked' => 0,
                'created' => self::AUTOFILL_TIMESTAMP ,
                'updated' => self::AUTOFILL_TIMESTAMP ,
            ),

            /**
             * 指定更新数据库中的对象时，哪些属性的值由下面指定的内容进行覆盖
             *
             * 填充值的指定规则同 create_autofill
             */
            'update_autofill' => array
            (
                'updated' => self::AUTOFILL_TIMESTAMP ,
            ),

            /**
             * 在保存对象时，会按照下面指定的验证规则进行验证。验证失败会抛出异常。
             *
             * 除了在保存时自动验证，还可以通过对象的 ::meta()->validate() 方法对数组数据进行验证。
             *
             * 如果需要添加一个自定义验证，应该写成
             *
             * 'title' => array(
             *        array(array(__CLASS__, 'checkTitle'), '标题不能为空'),
             * )
             *
             * 然后在该类中添加 checkTitle() 方法。函数原型如下：
             *
             * static function checkTitle($title)
             *
             * 该方法返回 true 表示通过验证。
             */
            'validations' => array
            (
                'name' => array
                (
                    array('not_empty', 'name不能为空'),
                    array('max_length', 255, 'name不能超过 255 个字符'),

                ),

                'sort' => array
                (
                    array('is_int', 'sort必须是一个整数'),

                ),

                'parent_id' => array
                (
                    array('is_int', 'parent_id必须是一个整数'),

                ),


            ),
        );
    }


/* ------------------ 以下是自动生成的代码，不能修改 ------------------ */

    /**
     * 开启一个查询，查找符合条件的对象或对象集合
     *
     * @static
     *
     * @return QDB_Select
     */
    static function find()
    {
        $args = func_get_args();
        return QDB_ActiveRecord_Meta::instance(__CLASS__)->findByArgs($args);
    }

    /**
     * 返回当前 ActiveRecord 类的元数据对象
     *
     * @static
     *
     * @return QDB_ActiveRecord_Meta
     */
    static function meta()
    {
        return QDB_ActiveRecord_Meta::instance(__CLASS__);
    }


/* ------------------ 以上是自动生成的代码，不能修改 ------------------ */

}

